package org.infinispan.distribution.ch.impl;

import org.infinispan.distribution.ch.KeyPartitioner;
import org.infinispan.distribution.group.impl.GroupManager;
import org.infinispan.distribution.group.impl.GroupingPartitioner;
import org.infinispan.factories.AbstractNamedCacheComponentFactory;
import org.infinispan.factories.AutoInstantiableFactory;
import org.infinispan.factories.annotations.DefaultFactoryFor;
import org.infinispan.factories.annotations.Inject;

/**
 * Key partitioner factory that uses the hash function defined in the configuration.
 *
 * In the future, we will probably remove the hash function from the configuration and leave only the
 * key partitioner.
 *
 * @author Dan Berindei
 * @since 8.2
 */
@DefaultFactoryFor(classes = KeyPartitioner.class)
public class KeyPartitionerFactory extends AbstractNamedCacheComponentFactory
      implements AutoInstantiableFactory {
   @Inject GroupManager groupManager;

   private KeyPartitioner getConfiguredPartitioner() {
      return configuration.clustering().hash().keyPartitioner();
   }

   @Override
   public Object construct(String componentName) {
      KeyPartitioner partitioner = getConfiguredPartitioner();
      if (groupManager == null)
         return new KeyPartitionerDelegate(partitioner, configuration);

      // Grouping is enabled. Since the configured partitioner will not be registered in the component
      // registry, we need to inject dependencies explicitly.
      basicComponentRegistry.wireDependencies(partitioner, false);
      return new KeyPartitionerDelegate(new GroupingPartitioner(partitioner, groupManager), configuration);
   }
}
